package j2024.j202410;

public class j1002 {
    /**
     * 383. 赎金信
     * 给你两个字符串：ransomNote 和 magazine ，判断 ransomNote 能不能由 magazine 里面的字符构成。
     *
     * 如果可以，返回 true ；否则返回 false 。
     *
     * magazine 中的每个字符只能在 ransomNote 中使用一次。
     * @param ransomNote
     * @param magazine
     * @return
     */
    public boolean canConstruct(String ransomNote, String magazine) {
        int[] h1 = new int[26];
        int[] h2 = new int[26];
        for (int i = 0; i < ransomNote.length(); i++) {
            h1[(ransomNote.charAt(i)-'a')]++;
        }
        for (int i = 0; i < magazine.length(); i++) {
            h1[(magazine.charAt(i)-'a')]++;
        }
        for (int i = 0; i < 26; i++) {
            if(h2[i]<h1[i]){
                return false;
            }
        }
        return true;
    }
}
